草庐IT

java - 重试 http 连接

全部标签

http - Golang 'http.NewRequest(method, url, body)' 无法创建正确格式的请求

我正在尝试向以下api发送GET请求:https://poloniex.com/public?command=returnOrderBook带URL参数:currencyPair=BTC_ETHdepth=20-->¤cyPair=BTC_ETH&depth=20我尝试这样设置和执行我的请求:(请注意,为简洁起见,我删除了错误检查)pair:="BTC_ETH"depth:=20reqURL:="https://poloniex.com/public?command=returnOrderBook"values:=url.Values{"currencyPair":[]st

sockets - 非常偶发的 Go HTTP 错误 : multiple response. WriteHeader 调用

我写了Kanali这是一个开源KubernetesIngress/API管理工具,对于大约1/200k请求,我收到以下fatalerror:2017/08/1612:40:57http:multipleresponse.WriteHeadercalls{"level":"error","method":"GET","msg":"unknownerror","time":"2017-08-16T12:40:57Z","uri":"/ommitted/path"}{"level":"fatal","msg":"writetcp4192.168.2.160:8443-\u003e192.16

http - 将 CURL 转换为 Golang 代码

我正在尝试在Golang中执行这个精确的CURL命令:curl-XGET-H"Content-Type:application/json"-H"WEB2PY-USER-TOKEN:token-string"-d'{"rfrID":"111111"}''url-string'有点奇怪,因为它是一个带有JSON正文的GETHTTP调用。然而,我们的vendor要求我们像这样调用API。我不知道如何让我们的Golang程序执行这个API。这是我到目前为止尝试过的Go代码:data:=Payload{//fillstructRfrID:"111111",}payloadBytes,err:=j

google-app-engine - 谷歌数据存储全局连接

您将如何为数据存储客户端声明一个全局变量?到目前为止,我有:var(dbdriver.Connctxcontext.Contextclientdatastore.Client)忽略数据库。这是我的全局数据库连接器。funcbootstrap(){ctx=context.Background()pId:=ProjectIdvarerrerrorclient,err=datastore.NewClient(ctx,pId)iferr!=nil{fmt.Printf("caughterror:%v\n",err)}}我的错误是:无法在多个分配中将*"cloud.google.com/go/d

go - 如何与 gorilla 复用器建立无状态连接?

我的程序在每次一个连接的情况下运行良好,但在并发连接的情况下就不行。我需要由一个函数呈现所有连接,该函数将包含我在服务中需要的所有数据,但效果不佳,因此我用下面的简单代码进行了说明:packagemainimport("encoding/json""fmt""github.com/gorilla/mux""github.com/rs/cors""net/http""reflect""time")varOutstruct{Codeint`json:"status"`Message[]interface{}`json:"message"`}funcClear(vinterface{}){p

Golang TCP 服务器读取 HTTP/2 帧

我正在尝试设置一个接受和解码HTTP/2数据的TCP服务器。实际解析帧的代码可以在这篇文章中找到:Decodinghttp2frameheader/datainGo但是,我在设置服务器时遇到了问题。连接被接受,但它卡在framer.ReadFrame()上。这是一个代码示例://generatewith:opensslreq-x509-newkeyrsa:4096-keyoutserver.key-outserver.pem-days365-nodescert,err:=tls.LoadX509KeyPair("server.pem","server.key")iferr!=nil{l

mongodb - 如何将本地Mongo数据库连接到docker

我正在从事golang项目,最近我阅读了有关docker的信息,并尝试在我的应用程序中使用docker。我正在使用mongoDB作为数据库。现在的问题是,我正在创建Dockerfile来安装所有包并编译和运行go项目。我在本地运行mongo数据,如果我在没有docker的情况下运行go程序,它会给我输出,但是如果我在同一个项目中使用docker(只是安装依赖项并运行这个项目),它编译成功但没有给出任何输出,有错误::CreateSession:noreachableservers我的Dockerfile::#StartfromaDebianimagewiththelatestversi

go - net/http 呈现根路由,即使我转到不存在的路由

我有这些路线:http.HandleFunc("/",func(whttp.ResponseWriter,r*http.Request){renderAndExecuteTemplate(w,r,"page/index.tmpl",nil)})http.HandleFunc("/route1",func(whttp.ResponseWriter,r*http.Request){renderAndExecuteTemplate(w,r,"page/route1.tmpl",nil)})http.HandleFunc("/route2",func(whttp.ResponseWriter,

http - Golang 中的 "Invalid memory address"使用 ioutil.ReadAll()

我目前正在学习Golang(到目前为止我很喜欢它)。但不幸的是,我已经被困了几个小时,而且我似乎没有在Google上找到任何解决我的问题的方法。所以这是我的问题。我有这段代码(来自教程):funcmain(){varsSitemapIndexresp,_:=http.Get("https://www.washingtonpost.com/news-sitemaps/index.xml")bytes,_:=ioutil.ReadAll(resp.Body)resp.Body.Close()xml.Unmarshal(bytes,&s)for_,Location:=ranges.Locat

postgresql - 微服务使 postgres 连接倍增

我有一个通过golang编写的服务,它作为消费者工作,它从kafka的队列中获取数据并将其存储在PostgreSQL数据库中。在执行某些请求时,golang开始增加PG连接,然后超过它们的限制。我不知道为什么,请帮我解决这个问题。这是代码:funcSaveMessageStatus(msgmodels.Message)error{db:=GetPostgreInstance()//Get*sql.DBinstance//Проверяеместьлизаписиrows,err:=db.Query(`select*from"tNotifStatus"where"Notification